<template>
  <div>
    <tiny-grid
      :fetch-data="fetchData"
      seq-serial
      ref="basicGridRef"
      :edit-config="{ trigger: 'click', mode: 'cell', showStatus: true }"
      :pager="pagerConfig"
    >
      <template #toolbar>
        <tiny-grid-toolbar>
          <template #buttons>
            <div>
              <tiny-button @click="$refs.basicGridRef.setAllSelection(true)">全选</tiny-button>
              <tiny-button @click="$refs.basicGridRef.clearSelection()">取消全选</tiny-button>
              <tiny-button @click="$refs.basicGridRef.revertData()">重置</tiny-button>
            </div>
          </template>
        </tiny-grid-toolbar>
        <tiny-grid-toolbar class="search-toolbar" setting full-screen>
          <template #buttons>
            <div>
              <tiny-search class="w-200" v-model="text" placeholder="请输入公司名称" @search="search"></tiny-search>
              <!-- <tiny-button class="ml-8" @click="search">搜索</tiny-button> -->
            </div>
          </template>
        </tiny-grid-toolbar>
      </template>
      <tiny-grid-column type="selection" width="40"></tiny-grid-column>
      <tiny-grid-column
        field="name"
        show-overflow
        title="名称"
        :show-icon="false"
        :editor="{ component: 'input', autoselect: true }"
      ></tiny-grid-column>
      <tiny-grid-column
        field="area"
        title="区域"
        :show-icon="false"
        sortable
        :editor="{ component: 'select', options }"
      ></tiny-grid-column>
      <tiny-grid-column
        field="address"
        title="地址"
        :show-icon="false"
        :editor="{ component: 'input', attrs: {} }"
      ></tiny-grid-column>
      <tiny-grid-column field="introduction" show-overflow title="公司简介"></tiny-grid-column>
    </tiny-grid>
  </div>
</template>

<script setup lang="jsx">
import { ref } from 'vue'
import { TinyPager, TinySearch, TinyButton, TinyGrid, TinyGridColumn, TinyGridToolbar } from '@opentiny/vue'

const pagerConfig = ref({
  component: TinyPager,
  attrs: {
    currentPage: 1,
    pageSize: 10,
    total: 0,
    layout: 'total, sizes, prev, pager, next, jumper'
  }
})
const options = ref([
  { label: '华中区', value: '华中区' },
  { label: '华东区', value: '华东区' },
  { label: '华南区', value: '华南区' },
  { label: '西南区', value: '西南区' }
])
const text = ref('')
const fetchData = ref({
  api: getData
})
const tableData = ref([
  {
    id: '1',
    name: 'GFD 科技 YX 公司',
    area: '华东区',
    address: '福州',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '2',
    name: 'WWWW 科技 YX 公司',
    area: '华南区',
    address: '深圳福田区',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '3',
    name: 'RFV 有限责任公司',
    area: '华南区',
    address: '中山市',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '4',
    name: 'TGBYX 公司',
    area: '华北区',
    address: '梅州',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '5',
    name: 'YHN 科技 YX 公司',
    area: '华南区',
    address: '韶关',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '6',
    name: '康康物业 YX 公司',
    area: '华北区',
    address: '广州天河区',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '7',
    name: '深圳市福德宝网络技术 YX 公司',
    area: '华南区',
    address: '清远',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '8',
    name: '西安门福德宝网络技术 YX 公司',
    area: '华东区',
    address: '厦门',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '9',
    name: 'WWWW 科技股份有限子公司',
    area: '华南区',
    address: '韶关',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  },
  {
    id: '10',
    name: 'WSX 科技 YX 公司',
    area: '华南区',
    address: '广州',
    introduction: '公司技术和研发实力雄厚，是国家 863 项目的参与者，并被政府认定为“高新技术企业”。'
  }
])
const basicGridRef = ref()

function getData({ page }) {
  let curPage = page.currentPage
  let pageSize = page.pageSize
  let offset = (curPage - 1) * pageSize

  return new Promise((resolve) => {
    resolve({
      result: tableData.value.slice(offset, offset + pageSize).filter((row) => row.name.includes(text.value)),
      page: { total: tableData.value.length }
    })
  })
}

function search() {
  basicGridRef.value.handleFetch()
}
</script>

<style scoped lang="less">
.search-toolbar {
  display: flex;
  :deep(.tiny-grid-button__wrapper) {
    flex: 1;
    padding-right: 4px;
  }
}
:deep(.tiny-grid) {
  &-header__column,
  &-body__column {
    &.col__selection,
    &.col__radio {
      padding: 0 8px 0 16px;
      & + th,
      + td {
        padding-left: 0;
      }
    }
  }
}
</style>
